package com.lhf.fvssystem.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.lhf.fvscommon.entity.SysPer;
import com.lhf.fvscommon.vo.SysPerOptionsVo;
import com.lhf.fvscommon.vo.SysPerTableVo;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Set;

/**
 * 权限表(SysPer)表数据库访问层
 *
 * @author lhf
 * @since 2020-10-26 10:57:10
 */
public interface SysPerDao extends BaseMapper<SysPer> {


    /**
     * 条件查询权限
     *
     * @param perName
     * @return
     */
    Set<SysPerOptionsVo> selectMenu(@Param("perName") String perName, @Param("perId") Integer perId);

    /**
     * 条件查询，并且分页
     *
     * @param per
     * @return
     */
    List<SysPerTableVo> selectByLimit(SysPer per);

    /**
     * 根据角色查询其所拥有的权限
     *
     * @param roleId
     * @return
     */
    List<SysPerOptionsVo> selectByRoleId(@Param("roleId") Integer roleId, @Param("parentId") Integer parentId);

    /**
     * 查询角色没有的权限信息
     *
     * @param roleId
     * @return
     */
    List<SysPer> selectNotExitByRoleId(@Param("roleId") Integer roleId);

    /**
     * 查询所有
     *
     * @return
     */
    List<SysPer> selectAll(Integer parentId);
}